## **Vision HDL Toolbox™** User's Guide

# MATLAB®



**R**2015**b** 

## How to Contact MathWorks



The MathWorks, Inc. 3 Apple Hill Drive Natick, MA 01760-2098

#### Vision HDL Toolbox<sup>™</sup> User's Guide

© COPYRIGHT 2015 by The MathWorks, Inc.

The software described in this document is furnished under a license agreement. The software may be used or copied only under the terms of the license agreement. No part of this manual may be photocopied or reproduced in any form without prior written consent from The MathWorks, Inc.

FEDERAL ACQUISITION: This provision applies to all acquisitions of the Program and Documentation by, for, or through the federal government of the United States. By accepting delivery of the Program or Documentation, the government hereby agrees that this software or documentation qualifies as commercial computer software or commercial computer software documentation as such terms are used or defined in FAR 12.212, DFARS Part 227.72, and DFARS 252.227-7014. Accordingly, the terms and conditions of this Agreement and only those rights specified in this Agreement, shall pertain to and govern the use, modification, reproduction, release, performance, display, and disclosure of the Program and Documentation by the federal government (or other entity acquiring for or through the federal government) and shall supersede any conflicting contractual terms or conditions. If this License fails to meet the government's needs or is inconsistent in any respect with federal procurement law, the government agrees to return the Program and Documentation, unused, to The MathWorks, Inc.

#### Trademarks

MATLAB and Simulink are registered trademarks of The MathWorks, Inc. See www.mathworks.com/trademarks for a list of additional trademarks. Other product or brand names may be trademarks or registered trademarks of their respective holders.

#### Patents

MathWorks products are protected by one or more U.S. patents. Please see www.mathworks.com/patents for more information.

#### **Revision History**

| March 2015     | Online only | New for Version 1.0 (Release R2015a)     |
|----------------|-------------|------------------------------------------|
| September 2015 | Online only | Revised for Version 1.1 (Release R2015b) |



## **Streaming Pixel Interface**

| Streaming Pixel Interface                               | 1-2 |
|---------------------------------------------------------|-----|
| What Is a Streaming Pixel Interface?                    | 1-2 |
| How Does a Streaming Pixel Interface Work?              | 1-2 |
| Why Use a Streaming Pixel Interface?                    | 1-3 |
| Pixel Stream Conversion Using Blocks and System Objects | 1-4 |
| Timing Diagram of Serial Pixel Interface                | 1-6 |
| Pixel Control Bus                                       | 1-8 |
| Pixel Control Structure                                 | 1-9 |

1

2

3

#### Algorithms

| Edgo Podding  | <br>2-2 |
|---------------|---------|
| Euge I auuing | <br>2-2 |

#### **Best Practices**

Accelerate a MATLAB Design With MATLAB Coder ..... 3-2

| HDL Code Generation from Vision HDL ToolboxWhat Is HDL Code Generation?HDL Code Generation Support in Vision HDL ToolboxStreaming Pixel Interface in HDL | 4-2<br>4-2<br>4-2<br>4-2 |
|----------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|
| Blocks and System Objects Supporting HDL Code                                                                                                            |                          |
| Generation                                                                                                                                               | 4-4                      |
| Blocks                                                                                                                                                   | 4-4                      |
| System Objects                                                                                                                                           | 4-4                      |
| Generate HDL Code From Simulink                                                                                                                          | 4-5                      |
| Introduction                                                                                                                                             | 4-5                      |
| Prepare Model                                                                                                                                            | 4-5                      |
| Generate HDL Code                                                                                                                                        | 4-5                      |
| Generate HDL Code From MATLAB                                                                                                                            | 4-7                      |
| Create an HDL Coder Project                                                                                                                              | 4-7                      |
| Generate HDL Code                                                                                                                                        | 4-7                      |
|                                                                                                                                                          |                          |
| HDL Cosimulation                                                                                                                                         | 4-9                      |
| FPGA-in-the-Loop                                                                                                                                         | 4-10                     |
|                                                                                                                                                          | 4-10                     |
| FIL In MATLAB                                                                                                                                            | 4-12                     |

4

## Streaming Pixel Interface

## **Streaming Pixel Interface**

#### In this section...

"What Is a Streaming Pixel Interface?" on page 1-2 "How Does a Streaming Pixel Interface Work?" on page 1-2 "Why Use a Streaming Pixel Interface?" on page 1-3 "Pixel Stream Conversion Using Blocks and System Objects" on page 1-4 "Timing Diagram of Serial Pixel Interface" on page 1-6

## What Is a Streaming Pixel Interface?

In hardware, processing an entire frame of video at one time has a high cost in memory and area. To save resources, serial processing is preferable in HDL designs. Vision HDL Toolbox blocks and System objects operate on a pixel, line, or neighborhood rather than a frame. The blocks and objects accept and generate video data as a serial stream of pixel data and control signals. The control signals indicate the relative location of each pixel within the image or video frame. The protocol mimics the timing of a video system, including inactive intervals between frames. Each block or object operates without full knowledge of the image format, and can tolerate imperfect timing of lines and frames.

## How Does a Streaming Pixel Interface Work?

Video capture systems scan video signals from left to right and from top to bottom. As these systems scan, they generate inactive intervals between lines and frames of active video.

The *horizontal blanking* interval is made up of the inactive cycles between the end of one line and the beginning of the next line. This interval is often split into two parts: the *front porch* and the *back porch*. These terms come from the synchronize pulse between lines in analog video waveforms. The *front porch* is the number of samples between the end of the active line and the synchronize pulse. The *back porch* is the number of samples between the synchronize pulse and the start of the active line.

The *vertical blanking* interval is made up of the inactive cycles between the *ending active line* of one frame and the *starting active line* of the next frame.

The scanning pattern requires start and end signals for both horizontal and vertical directions. The Vision HDL Toolbox streaming pixel protocol includes the blanking intervals, and allows you to configure the size of the active and inactive frame.



## Why Use a Streaming Pixel Interface?

#### Format Independence

The blocks and objects using this interface do not need a configuration option for the exact image size or the size of the inactive regions. In addition, if you change the image format for your design, you do not need to update each block or object. Instead, update the image parameters once at the serialization step. Some blocks and objects still require a line buffer size parameter to allocate memory resources.

By isolating the image format details, you can develop a design using a small image for faster simulation. Then once the design is correct, update to the actual image size.

#### **Error Tolerance**

Video can come from various sources such as cameras, tape storage, digital storage, or switching and insertion gear. These sources can introduce timing problems. Human vision cannot detect small variance in video signals, so the timing for a video system does not need to be perfect. Therefore, video processing blocks must tolerate variable timing of lines and frames.

By using a streaming pixel interface with control signals, each Vision HDL Toolbox block or object starts computation on a fresh segment of pixels at the start-of-line or start-offrame signal. The computation occurs whether or not the block or object receives the end signal for the previous segment.

The protocol tolerates minor timing errors. If the number of valid and invalid cycles between start signals varies, the blocks or objects continue to operate correctly. Some Vision HDL Toolbox blocks and objects require minimum horizontal blanking regions to accommodate memory buffer operations.

## **Pixel Stream Conversion Using Blocks and System Objects**

In Simulink<sup>®</sup>, use the Frame To Pixels block to convert framed video data to a stream of pixels and control signals that conform to this protocol. The control signals are grouped in a nonvirtual bus data type called pixelcontrol.

In MATLAB<sup>®</sup>, use the visionhdl.FrameToPixels object to convert framed video data to a stream of pixels and control signals that conform to this protocol. The control signals are grouped in a structure data type.

If your data is already in a serial format, design your own logic to generate these control signals from your existing serial control scheme.

#### Supported Pixel Data Types

Vision HDL Toolbox blocks and objects include ports or arguments for streaming pixel data. The blocks and objects capture one pixel at a time from the input, and produce one pixel at a time for output. Each block and object supports one or more pixel formats. The supported formats vary depending on the operation the block or object performs. This table details common video formats supported by Vision HDL Toolbox.

| Type of Video | Pixel Format                                                                                                                                                                                                               |
|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Binary        | Each pixel is represented by a single <b>boolean</b> or <b>logical</b> value. Used for true black-and-white video.                                                                                                         |
| Grayscale     | Each pixel is represented by <i>luma</i> , which is the gamma-corrected luminance value. This pixel is a single unsigned integer or fixed-point value.                                                                     |
| Color         | Each pixel has multiple unsigned integer or fixed-point values<br>representing the color components of the pixel. Vision HDL Toolbox<br>blocks and objects use gamma-corrected color spaces, such as R'G'B'<br>and Y'CbCr. |

Vision HDL Toolbox blocks have an input or output port, pixel, for the pixel data. Vision HDL Toolbox System objects expect or return an argument to the step method representing the pixel data. The following table describes the format of the pixel data.

| Port or Argument | Description                                                                                                          | Data Type                                                                                                                                                                                              |
|------------------|----------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| pixel            | Scalar that represents binary or grayscale<br>pixel value, or a vector of three values<br>representing color values. | <pre>Supported data types can<br/>include:     boolean or logical     uint or int     fixdt() double and single data types<br/>are supported for simulation but<br/>not for HDL code generation.</pre> |

#### **Streaming Pixel Control Signals**

Vision HDL Toolbox blocks and objects include ports or arguments for control signals relating to each pixel. These five control signals indicate the validity of a pixel and its location in the frame.

In Simulink, the control signal port is a nonvirtual bus data type called pixelcontrol. For details of the bus data type, see "Pixel Control Bus" on page 1-8.

In MATLAB, the control signal argument is a structure. For details of the structure data type, see "Pixel Control Structure" on page 1-9.

## **Timing Diagram of Serial Pixel Interface**

To illustrate the streaming pixel protocol, this example converts a frame to a sequence of control and data signals. Consider a 2-by-3 pixel image. To model the blanking intervals, configure the serialized image to include inactive pixels in these areas around the active image:

- 1-pixel-wide back porch
- 2-pixel-wide front porch
- 1 line before the first active line
- 1 line after the last active line

You can configure the dimensions of the active and inactive regions with the Frame To Pixels block or FrameToPixels object.

In the figure, the active image area is in the dashed rectangle, and the inactive pixels surround it. The pixels are labeled with their grayscale values.



The block or object serializes the image from left to right, one line at a time. The timing diagram shows the control signals and pixel data that correspond to this image. The diagram shows the serial output of the Frame To Pixels block for this frame.



For an example using the Frame to Pixels block to serialize an image, see "Design Video Processing Algorithms for HDL in Simulink".

For an example using the FrameToPixels object to serialize an image, see "Design Video Processing Algorithms for HDL in MATLAB".

#### See Also

## **Pixel Control Bus**

Vision HDL Toolbox blocks use a nonvirtual bus data type, pixelcontrol, for control signals associated with serial pixel data. The bus contains 5 boolean signals indicating the validity of a pixel and its location within a frame. You can easily connect the data and control output of one block to the input of another, because Vision HDL Toolbox blocks use this bus for input and output. To convert an image into a pixel stream and a pixelcontrol bus, use the Frame to Pixels block.

| Signal | Description                                                     | Data Type |
|--------|-----------------------------------------------------------------|-----------|
| hStart | true for the first pixel in a horizontal line of a frame        | boolean   |
| hEnd   | true for the last pixel in a horizontal line of a frame         | boolean   |
| vStart | true for the first pixel in the first (top) line of a frame     | boolean   |
| vEnd   | true for the last pixel in the last (bottom)<br>line of a frame | boolean   |
| valid  | true for any valid pixel                                        | boolean   |

#### See Also

Frame To Pixels | pixelcontrolbus | Pixels To Frame

## More About

• "Streaming Pixel Interface" on page 1-2

## **Pixel Control Structure**

Vision HDL Toolbox System objects use a structure data type for control signals associated with serial pixel data. The structure contains five logical signals indicating the validity of a pixel and its location within a frame. You can easily connect the data and control output of a step method to the input of another step method, because Vision HDL Toolbox objects use this structure for input and output. To convert an image into a pixel stream and control signals, use the FrameToPixels object.

| Signal | Description                                                     | Data Type |
|--------|-----------------------------------------------------------------|-----------|
| hStart | true for the first pixel in a horizontal line of a frame        | logical   |
| hEnd   | true for the last pixel in a horizontal line of a frame         | logical   |
| vStart | true for the first pixel in the first (top) line of a frame     | logical   |
| vEnd   | true for the last pixel in the last (bottom)<br>line of a frame | logical   |
| valid  | true for any valid pixel                                        | logical   |

### See Also

visionhdl.FrameToPixels | visionhdl.PixelsToFrame | pixelcontrolsignals |
pixelcontrolstruct

## More About

• "Streaming Pixel Interface" on page 1-2

## Algorithms

## **Edge Padding**

To perform a kernel-based operation such as filtering on a pixel at the edge of a frame, Vision HDL Toolbox algorithms pad the edges of the frame with extra pixels. These padding pixels are used for internal calculation only. The output frame has the same dimensions as the input frame. The padding operation assigns a pattern of pixel values to the inactive pixels around a frame. Vision HDL Toolbox algorithms provide padding by constant value, replication, or symmetry. Some blocks and System objects enable you to select from these padding methods.

The diagrams show the top-left corner of a frame, with padding added to accommodate a  $5 \times 5$  filter kernel. When computing the filtered value for the top-left active pixel, the algorithm requires two rows and two columns of padding. The edge of the active image is indicated by the double line.

• Constant — Each added pixel is assigned the same value. On some blocks and System objects you can specify the constant value. The value 0, representing black, is a reserved value in some video standards. It is common to choose a small number, such as 16, as a near-black padding value.

In the diagram, C represents the constant value assigned to the inactive pixels around the active frame.

| С | С | С   | С   | С   |
|---|---|-----|-----|-----|
| С | С | С   | С   | С   |
| С | С | 30  | 60  | 90  |
| С | С | 120 | 150 | 180 |

• **Replicate** — The pixel values at the edge of the active frame are repeated to make rows and columns of padding pixels.

The diagram shows the pattern of replicated values assigned to the inactive pixels around the active frame.

| 30  | 30  | 30  | 60  | 90  |
|-----|-----|-----|-----|-----|
| 30  | 30  | 30  | 60  | 90  |
| 30  | 30  | 30  | 60  | 90  |
| 120 | 120 | 120 | 150 | 180 |

• Symmetric — The padding pixels are added such that they mirror the edge of the image.

The diagram shows the pattern of symmetric values assigned to the inactive pixels around the active frame. The pixel values are symmetric about the edge of the image in both dimensions.

| 150 | 120 | 120 | 150 | 180 |
|-----|-----|-----|-----|-----|
| 60  | 30  | 30  | 60  | 90  |
| 60  | 30  | 30  | 60  | 90  |
| 150 | 120 | 120 | 150 | 180 |

Padding requires minimum horizontal and vertical blanking periods. This interval gives the algorithm time to add and store the extra pixels. The blanking period, or inactive pixel region, must be at least *kernel size* pixels in each dimension.

## See Also

visionhdl.ImageFilter | Image Filter

## More About

• "Streaming Pixel Interface" on page 1-2

## **Best Practices**

## Accelerate a MATLAB Design With MATLAB Coder

Vision HDL Toolbox designs in MATLAB must call the step method of one or more System objects for every pixel. This serial processing is efficient in hardware, but is slow in simulation. One way to accelerate simulations of these objects is to simulate using generated C code rather than the MATLAB interpreted language.

Code generation accelerates simulation by locking down the sizes and data types of variables inside the function. This process removes the overhead of the interpreted language checking for size and data type in every line of code. You can compile a video processing algorithm and test bench into MEX functions, and use the resulting MEX file to speed up the simulation.

To generate C code, you must have a MATLAB Coder<sup>™</sup> license.

See "Accelerate a Pixel-Streaming Design Using MATLAB Coder".

## Prototyping

4

## HDL Code Generation from Vision HDL Toolbox

#### In this section...

"What Is HDL Code Generation?" on page 4-2

"HDL Code Generation Support in Vision HDL Toolbox" on page 4-2

"Streaming Pixel Interface in HDL" on page 4-2

## What Is HDL Code Generation?

You can use MATLAB and Simulink for rapid prototyping of hardware designs. Vision HDL Toolbox blocks and System objects, when used with HDL Coder<sup>™</sup>, provide support for HDL code generation. HDL Coder tools generate target-independent synthesizable Verilog and VHDL code for FPGA programming or ASIC prototyping and design.

## HDL Code Generation Support in Vision HDL Toolbox

All blocks and objects in Vision HDL Toolbox, except for those used for frame-to-pixels and pixels-to-frame conversion, support HDL code generation.

## **Streaming Pixel Interface in HDL**

The streaming pixel bus and structure data type used by Vision HDL Toolbox blocks and System objects is flattened into separate signals in HDL.

In VHDL, the interface is declared as:

| PORT ( | clk         | : | IN  | <pre>std_logic;</pre>                          |
|--------|-------------|---|-----|------------------------------------------------|
|        | reset       | : | IN  | <pre>std_logic;</pre>                          |
|        | enb         | : | IN  | <pre>std_logic;</pre>                          |
|        | inO         | : | IN  | <pre>std_logic_vector(7 DOWNTO 0); uint8</pre> |
|        | in1_hStart  | : | IN  | <pre>std_logic;</pre>                          |
|        | in1_hEnd    | : | IN  | <pre>std_logic;</pre>                          |
|        | in1_vStart  | : | IN  | <pre>std_logic;</pre>                          |
|        | in1_vEnd    | : | IN  | <pre>std_logic;</pre>                          |
|        | in1_valid   | : | IN  | <pre>std_logic;</pre>                          |
|        | out0        | : | OUT | <pre>std_logic_vector(7 DOWNTO 0); uint8</pre> |
|        | out1_hStart | : | OUT | <pre>std_logic;</pre>                          |
|        | out1_hEnd   | : | OUT | <pre>std_logic;</pre>                          |
|        | out1_vStart | : | OUT | <pre>std_logic;</pre>                          |

| out1_vEnd  | : | OUT | <pre>std_logic;</pre> |
|------------|---|-----|-----------------------|
| out1_valid | : | OUT | std_logic             |
| );         |   |     |                       |

In Verilog, the interface is declared as:

| input  | clk;                 |
|--------|----------------------|
| input  | reset;               |
| input  | enb;                 |
| input  | [7:0] in0; // uint8  |
| input  | in1_hStart;          |
| input  | in1_hEnd;            |
| input  | in1_vStart;          |
| input  | in1_vEnd;            |
| input  | in1_valid;           |
| output | [7:0] out0; // uint8 |
| output | out1_hStart;         |
| output | out1_hEnd;           |
| output | out1_vStart;         |
| output | out1_vEnd;           |
| output | out1_valid;          |

## Blocks and System Objects Supporting HDL Code Generation

All blocks and objects in Vision HDL Toolbox, except for Frame To Pixels and Pixels To Frame conversions, are supported for HDL code generation. This page helps you find blocks and objects supported for HDL code generation in other MathWorks<sup>®</sup> products.

## Blocks

You can find libraries of blocks supported for HDL code generation in the Simulink library browser. Find Simulink blocks that support HDL code generation, in the 'HDL Coder' library. You can also type hdlsllib at the MATLAB command prompt to open this library.

Create a library of HDL-supported blocks from all products you have installed, by typing hdllib at the MATLAB command line. This command requires an HDL Coder license. For more information on this command, see hdllib in the HDL Coder documentation.

Refer to the "Supported Blocks" pages in HDL Coder documentation for block implementations, properties, and restrictions for HDL code generation.

## System Objects

To find System objects supported for HDL code generation, see Predefined System Objects in the HDL Coder documentation.

## Generate HDL Code From Simulink

## Introduction

This example shows you how to generate HDL code from the design described in "Design Video Processing Algorithms for HDL in Simulink". This example generates HDL code from the HDL Algorithm block in the model.

To generate HDL code, you must have an HDL Coder license.

### **Prepare Model**

Run hdlsetup to configure the model for HDL code generation. If you started your design using the Vision HDL Toolbox Simulink model template, your model is already configured for HDL code generation.

## **Generate HDL Code**

Right-click the HDL Algorithm block, and select **HDL Code > Generate HDL from subsystem** to generate HDL using the default settings. The output of this operation is shown in the MATLAB Command Window.

```
### Generating HDL for 'template hdlcodegen/HDL Algorithm'.
### Starting HDL check.
### Begin VHDL Code Generation for 'template hdlcodegen'.
### Working on template hdlcodegen/HDL Algorithm/Image Filter/LineBuffer/FIFOHandlerFS
### Working on template hdlcodegen/HDL Algorithm/Image Filter/LineBuffer/dataReadFSM as
### Working on template hdlcodegen/HDL Algorithm/Image Filter/LineBuffer/dataWriteFSM a
### Working on template hdlcodegen/HDL Algorithm/Image Filter/LineBuffer/lineSpaceAvera
### Working on template hdlcodegen/HDL Algorithm/Image Filter/LineBuffer/DataMemory/Pu
### Working on template hdlcodegen/HDL Algorithm/Image Filter/LineBuffer/DataMemory/FI
### Working on template hdlcodegen/HDL Algorithm/Image Filter/LineBuffer/DataMemory/ad
### Working on template hdlcodegen/HDL Algorithm/Image Filter/LineBuffer/DataMemory/is
```

```
### Working on template_hdlcodegen/HDL Algorithm/Image Filter/LineBuffer/DataMemory/und
### Working on template_hdlcodegen/HDL Algorithm/Image Filter/LineBuffer/DataMemory as
### Working on template_hdlcodegen/HDL Algorithm/Image Filter/LineBuffer/validPipeline
### Working on template_hdlcodegen/HDL Algorithm/Image Filter/LineBuffer/horizontalPade
### Working on template_hdlcodegen/HDL Algorithm/Image Filter/LineBuffer/horizontalPade
### Working on template_hdlcodegen/HDL Algorithm/Image Filter/LineBuffer/horizontalMux
### Working on template_hdlcodegen/HDL Algorithm/Image Filter/LineBuffer/verticalMux as
### Working on template_hdlcodegen/HDL Algorithm/Image Filter/LineBuffer as hdl_prj\hd
### Working on template_hdlcodegen/HDL Algorithm/Image Filter as hdl_prj\hd
### Working on template_hdlcodegen/HDL Algorithm/Image Filter as hdl_prj\hd
### Working on template_hdlcodegen/HDL Algorithm as hdl_prj\hdlsrc\template_hdlcodegen'
### Working on template_hdlcodegen/HDL Algorithm as hdl_prj\hdlsrc\template_hdlcodegen'
### Working on template_hdlcodegen/HDL Algorithm as hdl_prj\hdlsrc\template_hdlcodegen'
### HDL code Generation Check Report HDL_Algorithm_report.html
### HDL check for 'template_hdlcodegen' complete with 0 errors, 0 warnings, and 0 messa
### HDL code generation complete.
```

To change code generation options, or to select a target device or synthesis tool, rightclick on the HDL Algorithm block, and select **HDL Code** > **HDL Workflow Advisor**.

#### **Related Examples**

- "Generate Code Using the HDL Workflow Advisor"
- "Generate HDL Code Using the Command Line"

## Generate HDL Code From MATLAB

This example show you how to generate HDL code from the design in "Design Video Processing Algorithms for HDL in MATLAB".

To generate HDL code, you must have an HDL Coder license.

## **Create an HDL Coder Project**

Copy the relevant files to a temporary folder.

```
functionName = 'HDLTargetedDesign';
tbName = 'VisionHDLMATLABTutorialExample';
vhtExampleDir = fullfile(matlabroot,'examples','visionhdl');
workDir = [tempdir 'vht_matlabhdl_ex'];
cd(tempdir);
[~, ~, ~] = rmdir(workDir, 's');
mkdir(workDir);
cd(workDir);
copyfile(fullfile(vhtExampleDir, [functionName,'.m*']), workDir);
copyfile(fullfile(vhtExampleDir, [tbName,'.m*']), workDir);
```

Open the HDL Coder app and create a new project.

coder -hdlcoder -new vht\_matlabhdl\_ex

In the **HDL Code Generation** pane, add the function file **HDLTargetedDesign.m** and the test bench file **VisionHDLMATLABTutorialExample.m** to the project.

Click next to the signal names under **MATLAB Function** to define the data types for the input and output signals of the function. The control signals are **logical** scalars. The pixel data type is **uint8**. The pixel input is a scalar.

## **Generate HDL Code**

- 1 Click Workflow Advisor to open the advisor.
- 2 Click HDL Code Generation to view the HDL code generation options.
- 3 On the Target tab, set Language to Verilog or VHDL.

- 4 Also on the Target tab, select Generate HDL and Generate HDL test bench.
- **5** On the **Coding Style** tab, select **Include MATLAB source code as comments** and **Generate report** to generate a code generation report with comments and traceability links.
- **6** Click **Run** to generate the HDL design and the test bench with reports.

Examine the log window and click the links to view the generated code and the reports.

## **Related Examples**

- "Getting Started with MATLAB to HDL Workflow"
- "Generate HDL Code from MATLAB Code Using the Command Line Interface"
- "HDL Code Generation for System Objects"
- "Pixel-Streaming Design in MATLAB"

## **HDL** Cosimulation

HDL cosimulation links an HDL simulator with MATLAB or Simulink. This communication link enables integrated verification of the HDL implementation against the design. To perform this integration, you need an HDL Verifier<sup>™</sup> license. HDL Verifier cosimulation tools enable you to:

- Use MATLAB or Simulink to create test signals and software test benches for HDL code
- Use MATLAB or Simulink to provide a behavioral model for an HDL simulation
- Use MATLAB analysis and visualization capabilities for real-time insight into an HDL implementation
- · Use Simulink to translate legacy HDL descriptions into system-level views

## More About

• "HDL Cosimulation"

## FPGA-in-the-Loop

FPGA-in-the-loop (FIL) enables you to run a Simulink or MATLAB simulation that is synchronized with an HDL design running on an Altera<sup>®</sup> or Xilinx<sup>®</sup> FPGA board. This link between the simulator and the board enables you to verify HDL implementations directly against Simulink or MATLABalgorithms. You can apply real-world data and test scenarios from these algorithms to the HDL design on the FPGA.

Vision HDL Toolbox provides the FIL Frame To Pixels and FIL Pixels To Frame blocks to accelerate communication between Simulink and the FPGA board. In MATLAB, you can modify the generated code to speed up communication with the FPGA board.

```
In this section...
```

"FIL In Simulink" on page 4-10

"FIL In MATLAB" on page 4-12

## **FIL In Simulink**

#### **Autogenerated FIL Model**

When you generate a programming file for a FIL target in Simulink, the tool creates a model to compare the FIL simulation with your Simulink design. For Vision HDL Toolbox designs, the FIL block in that model replicates the pixel-streaming interface and sends one pixel at a time to the FPGA.



The blue ToFILSrc subsystem branches the pixel-stream input of the HDL Algorithm block to the FromFILSrc subsystem. The blue ToFILSink subsystem branches the pixel-stream output of the HDL Algorithm block into the Compare subsystem, where it is compared with the output of the HDL Algorithm\_fil block. For image and video processing, this setup is slow because the model sends only a single pixel, and its associated control signals, in each packet to and from the FPGA board.

#### Modified FIL Model for Pixel Streaming

To improve the communication bandwidth with the FPGA board, you can modify the autogenerated model. The modified model uses the FIL Frame To Pixels and FIL Pixels To Frame blocks to sending one frame at a time.



- 1 Remove the blue subsystems, and create a branch at the full-frame input of the Frame To Pixels block.
- **2** Insert the FIL Frame To Pixels block before the HDL Algorithm\_fil block. Insert the FIL Pixels To Frame block after the HDL Algorithm\_fil block.
- **3** Branch the full-frame output of the Pixels To Frame block for comparison. You can compare the entire frame at once with a Diff block. Compare the validOut signals using an XOR block.
- **4** In the FIL Frame To Pixels and FIL Pixels To Frame blocks, set the **Video format** parameter to match the video format of the Frame To Pixels and Pixels To Frame blocks.
- 5 Select the Vector size in the FIL Frame To Pixels and FIL Pixels To Frame blocks as Frame or Line. The size of the FIL Frame To Pixels vector output must match the size of the FIL Pixels To Frame vector input. The vector size of the interfaces of the

FIL block does not modify the generated HDL code. It affects only the packet size of the communication between the simulator and the FPGA board.

This modified model sends an entire frame to the FPGA board in each packet, significantly improving the efficiency of the communication link.

## **FIL In MATLAB**

#### **Autogenerated FIL Function**

When you generate a programming file for a FIL target in MATLAB, the tool creates a test bench to compare the FIL simulation with your MATLAB design. For Vision HDL Toolbox designs, the *name\_fil* function in the test bench replicates the pixel-streaming interface and sends one pixel at a time to the FPGA.

This code snippet is from the generated test bench *name\_tb\_fil.m*. The code calls the generated *name\_fil* function once for each pixel in a frame.

The generated *name\_fil* function calls your HDL-targeted function. It also calls the *namesysobj\_fil* function, which contains a System object<sup>™</sup> that connects to the FPGA. *name\_fil* compares the output of the two functions to verify the that FPGA implementation matches the original MATLAB results. This snippet is from the file *name\_fil.m*.

```
% Call the original MATLAB function to get reference signal
[ref_pixOut,ref_hStartOut,ref_hEndOut,ref_vStartOut,ref_vEndOut,ref_validOut] = ...
visionhdlgamma_design(pixIn,hStartIn,hEndIn,vStartIn,vEndIn,validIn);
```

```
% Run FPGA-in-the-loop
[pixOut,hStartOut,vEndOut,vEndOut,validOut] = ...
visionhdlgamma_design_sysobj_fil(pixIn,hStartIn,hEndIn,vStartIn,vEndIn,valid)
```

```
% Convert output signals
hStartOut = logical(hStartOut);
hEndOut = logical(hEndOut);
vStartOut = logical(vStartOut);
```

```
vEndOut = logical(vEndOut);
validOut = logical(validOut);
% Verify the FPGA-in-the-loop output against the reference
hdlverifier.assert(pixOut,ref_pixOut,'pixOut');
hdlverifier.assert(hStartOut,ref_hStartOut,'hStartOut');
hdlverifier.assert(hEndOut,ref_hEndOut,'hEndOut');
hdlverifier.assert(vStartOut,ref_vStartOut,'vStartOut');
hdlverifier.assert(vEndOut,ref_vEndOut,'vEndOut');
hdlverifier.assert(validOut,ref_validOut,'validOut');
```

For image and video processing, this setup is slow because the function sends only one pixel, and its associated control signals to and from the FPGA board at a time.

#### Modified FIL Test Bench for Pixel Streaming

To improve the communication bandwidth with the FPGA board, you can modify the autogenerated test bench, *name\_tb\_fil.m*. The modified test bench calls the FIL System object directly, with one frame at a time.

Declare an instance of the class\_*name\_sysobj* System object. Preallocate vectors for the input pixel data and control signals.

```
fil = class_visionhdlgamma_design_sysobj;
hStartIn = true(numPixPerFrm,1);
hEndIn = true(numPixPerFrm,1);
vStartIn = true(numPixPerFrm,1);
vEndIn = true(numPixPerFrm,1);
validIn = true(numPixPerFrm,1);
```

Comment out the loop over the pixels in the frame, as well as the call to the pix2frm object.

```
% for p = 1:numPixPerFrm
% [hStartIn(p),hEndIn(p),vStartIn(p),vEndIn(p),validIn(p)] = pixelcontrolsignals
% [pixOut(p),hStartOut,hEndOut,vStartOut,vEndOut,validOut] =...
% visionhdlgamma_design_fil(pixIn(p),hStartIn(p),hEndIn(p),vStartIn(p),vEndIn
% ctrlOut(p) = pixelcontrolstruct(hStartOut,hEndOut,vStartOut,vEndOut,validOut);
% end
% frmOut = step(pix2frm,pixOut,ctrlOut);
```

Call the step method of the class\_name\_sysobj object with vectors containing the whole frame of data pixels and control signals. Pass each control signal to step separately, as a vector of logical values. After this step call, recombine the control signal vectors into a vector of structures. Convert the vector data back to a matrix representing the active frame using the pix2frm object.

```
[fil_pixOut,fil_hStartOut,fil_hEndOut,fil_vStartOut,fil_vEndOut,fil_validOut] = ...
step(fil,pixIn,[ctrlIn.hStart]',[ctrlIn.hEnd]',[ctrlIn.vStart]',[ctrlIn.vEnd]',[ctr
fil_ctrlOut = arrayfun(@(hStart,hEnd,vStart,vEnd,valid) ...
struct('hStart',hStart,'hEnd',hEnd,'vStart',vStart,'vEnd',vEnd,'valid',valid), ...
fil_hStartOut,fil_hEndOut,fil_vStartOut,fil_vEndOut,fil_validOut);
frmOut_fil = step(pix2frm,fil_pixOut,fil_ctrlOut);
```

These code changes remove the pixel-by-pixel verification of the FIL results against the MATLAB results. Optionally, you can add a frame-by-frame comparison of the results. Calling the original pixel-by-pixel function for a reference slows down the FIL simulation. Leave the pixel loop intact, but instead of calling *name\_fil*, call the original *name* function.

```
for p = 1:numPixPerFrm
```

```
[hStartIn,hEndIn,vStartIn,vEndIn,validIn] = pixelcontrolsignals(ctrlIn(p));
[ref_pixOut(p),hStartOut,hEndOut,vStartOut,vEndOut,validOut] = visionhdlgamma_design
pixIn(p),hStartIn,hEndIn,vStartIn,vEndIn,validIn);
ref_ctrlOut(p) = pixelcontrolstruct(hStartOut,hEndOut,vStartOut,vEndOut,validOut);
end
After the cell to the place name pyochic chief arms on the two entert exctants.
```

After the call to the class\_name\_sysobj object, compare the two output vectors.

```
hdlverifier.assert(fil_pixOut,ref_pixOut,'pixOut');
hdlverifier.assert(fil_ctrlOut,ref_ctrlOut,'ctrlOut');
```

This modified test bench sends an entire frame to the FPGA board in each packet, significantly improving the efficiency of the communication link.

### More About

"FPGA Verification"